home *** CD-ROM | disk | FTP | other *** search
/ Disc to the Future 2 / Disc to the Future Part II Programmer's Reference (Wayzata Technology)(6013)(1992).bin / MAC / OTHERCST / JPSRC_FO / JCONFIG.H < prev    next >
Text File  |  1991-10-13  |  10KB  |  321 lines

  1. /*
  2.  * jconfig.h
  3.  *
  4.  * Copyright (C) 1991, Thomas G. Lane.
  5.  * This file is part of the Independent JPEG Group's software.
  6.  * For conditions of distribution and use, see the accompanying README file.
  7.  *
  8.  * This file contains preprocessor declarations that help customize
  9.  * the JPEG software for a particular application, machine, or compiler.
  10.  * Edit these declarations as needed (or add -D flags to the Makefile).
  11.  */
  12.  
  13.  
  14. /*
  15.  * These symbols indicate the properties of your machine or compiler.
  16.  * The conditional definitions given may do the right thing already,
  17.  * but you'd best look them over closely, especially if your compiler
  18.  * does not handle full ANSI C.  An ANSI-compliant C compiler should
  19.  * provide all the necessary features; __STDC__ is supposed to be
  20.  * predefined by such compilers.
  21.  */
  22.  
  23. /* Does your compiler support function prototypes? */
  24. /* (If not, you also need to use ansi2knr, see README) */
  25.  
  26. #ifdef __STDC__            /* ANSI C compilers always have prototypes */
  27. #define PROTO
  28. #else
  29. #ifdef __cplusplus        /* So do C++ compilers */
  30. #define PROTO
  31. #endif
  32. #endif
  33.  
  34. /* Does your compiler support the declaration "unsigned char" ? */
  35. /* How about "unsigned short" ? */
  36.  
  37. #ifdef __STDC__            /* ANSI C compilers must support both */
  38. #define HAVE_UNSIGNED_CHAR
  39. #define HAVE_UNSIGNED_SHORT
  40. #endif
  41.  
  42. /* Define this if an ordinary "char" type is unsigned.
  43.  * If you're not sure, leaving it undefined will work at some cost in speed.
  44.  * If you defined HAVE_UNSIGNED_CHAR then it doesn't matter very much.
  45.  */
  46.  
  47. /* #define CHAR_IS_UNSIGNED */
  48.  
  49. /* Define this if your compiler implements ">>" on signed values as a logical
  50.  * (unsigned) shift; leave it undefined if ">>" is a signed (arithmetic) shift,
  51.  * which is the normal and rational definition.
  52.  * The DCT and IDCT routines will compute wrong values if you get this wrong!
  53.  */
  54.  
  55. /* #define RIGHT_SHIFT_IS_UNSIGNED */
  56.  
  57. /* Define "void" as "char" if your compiler doesn't know about type void.
  58.  * NOTE: be sure to define void such that "void *" represents the most general
  59.  * pointer type, e.g., that returned by malloc().
  60.  */
  61.  
  62. /* #define void char */
  63.  
  64. /* Define const as empty if your compiler doesn't know the "const" keyword. */
  65. /* (Even if it does, defining const as empty won't break anything.) */
  66.  
  67. #ifndef __STDC__        /* ANSI C and C++ compilers should know it. */
  68. #ifndef __cplusplus
  69. #define const
  70. #endif
  71. #endif
  72.  
  73. /* For 80x86 machines, you need to define NEED_FAR_POINTERS,
  74.  * unless you are using a large-data memory model or 80386 flat-memory mode.
  75.  * On less brain-damaged CPUs this symbol must not be defined.
  76.  * (Defining this symbol causes large data structures to be referenced through
  77.  * "far" pointers and to be allocated with a special version of malloc.)
  78.  */
  79.  
  80. #ifdef MSDOS            /* Microsoft C and compatibles */
  81. #define NEED_FAR_POINTERS
  82. #else
  83. #ifdef __TURBOC__        /* Turbo C doesn't define MSDOS */
  84. #define NEED_FAR_POINTERS
  85. #endif
  86. #endif
  87.  
  88.  
  89. /* The next couple of symbols only affect the system-dependent user interface
  90.  * modules (jcmain.c, jdmain.c).  You can ignore these if you are supplying
  91.  * your own user interface code.
  92.  */
  93.  
  94. /* Define this if you want to name both input and output files on the command
  95.  * line, rather than using stdout and optionally stdin.  You MUST do this if
  96.  * your system can't cope with binary I/O to stdin/stdout.  See comments at
  97.  * head of jcmain.c or jdmain.c.
  98.  */
  99.  
  100. #ifdef MSDOS            /* two-file style is needed for PCs */
  101. #define TWO_FILE_COMMANDLINE
  102. #else
  103. #ifdef __TURBOC__        /* Turbo C doesn't define MSDOS */
  104. #define TWO_FILE_COMMANDLINE
  105. #endif
  106. #endif
  107. #ifdef THINK_C            /* needed for Macintosh too */
  108. #define TWO_FILE_COMMANDLINE
  109. #endif
  110.  
  111. /* By default, we open image files with fopen(...,"rb") or fopen(...,"wb").
  112.  * This is necessary on systems that distinguish text files from binary files,
  113.  * and is harmless on most systems that don't.  If you have one of the rare
  114.  * systems that complains about the "b" spec, define this symbol.
  115.  */
  116.  
  117. /* #define DONT_USE_B_MODE */
  118.  
  119.  
  120. /* If you're getting bored, that's the end of the symbols you HAVE to
  121.  * worry about.  Go fix the makefile and compile.
  122.  */
  123.  
  124.  
  125. /* If your compiler supports inline functions, define INLINE as
  126.  * the inline keyword; otherwise define it as empty.
  127.  */
  128.  
  129. #ifdef __GNUC__            /* GNU C has inline... */
  130. #define INLINE inline
  131. #else                /* ...but I don't think anyone else does. */
  132. #define INLINE
  133. #endif
  134.  
  135. /* On a few systems, type boolean and/or macros FALSE, TRUE may appear
  136.  * in standard header files.  Or you may have conflicts with application-
  137.  * specific header files that you want to include together with these files.
  138.  * In that case you need only comment out these definitions.
  139.  */
  140.  
  141. typedef int boolean;
  142. #define FALSE    0        /* values of boolean */
  143. #define TRUE    1
  144.  
  145. /* This defines the size of the I/O buffers for entropy compression
  146.  * and decompression; you could reduce it if memory is tight.
  147.  */
  148.  
  149. #define JPEG_BUF_SIZE    4096 /* bytes */
  150.  
  151.  
  152.  
  153. /* These symbols determine the JPEG functionality supported. */
  154.  
  155. /*
  156.  * These defines indicate whether to include various optional functions.
  157.  * Undefining some of these symbols will produce a smaller but less capable
  158.  * program file.  Note that you can leave certain source files out of the
  159.  * compilation/linking process if you've #undef'd the corresponding symbols.
  160.  * (You may HAVE to do that if your compiler doesn't like null source files.)
  161.  */
  162.  
  163. /* Arithmetic coding is unsupported for legal reasons.  Complaints to IBM. */
  164. #undef  ARITH_CODING_SUPPORTED    /* Arithmetic coding back end? */
  165. #define MULTISCAN_FILES_SUPPORTED /* Multiple-scan JPEG files? */
  166. #define ENTROPY_OPT_SUPPORTED    /* Optimization of entropy coding parms? */
  167. #define BLOCK_SMOOTHING_SUPPORTED /* Block smoothing during decoding? */
  168. #define QUANT_1PASS_SUPPORTED    /* 1-pass color quantization? */
  169. #undef  QUANT_2PASS_SUPPORTED    /* 2-pass color quantization? (not yet impl.) */
  170. /* these defines indicate which JPEG file formats are allowed */
  171. #define JFIF_SUPPORTED        /* JFIF or "raw JPEG" files */
  172. #undef  JTIFF_SUPPORTED        /* JPEG-in-TIFF (not yet implemented) */
  173. /* these defines indicate which image (non-JPEG) file formats are allowed */
  174. #define PPM_SUPPORTED        /* PPM/PGM image file format */
  175. #define GIF_SUPPORTED        /* GIF image file format */
  176. #undef  TIFF_SUPPORTED        /* TIFF image file format (not yet impl.) */
  177.  
  178. /* more capability options later, no doubt */
  179.  
  180.  
  181. /*
  182.  * Define exactly one of these three symbols to indicate whether you want
  183.  * 8-bit, 12-bit, or 16-bit sample (pixel component) values.  8-bit is the
  184.  * default and is nearly always the right thing to use.  You can use 12-bit if
  185.  * you need to support image formats with more than 8 bits of resolution in a
  186.  * color value.  16-bit should only be used for the lossless JPEG mode (not
  187.  * currently supported).  Note that 12- and 16-bit values take up twice as
  188.  * much memory as 8-bit!
  189.  */
  190.  
  191. #define EIGHT_BIT_SAMPLES
  192. #undef  TWELVE_BIT_SAMPLES
  193. #undef  SIXTEEN_BIT_SAMPLES
  194.  
  195.  
  196.  
  197. /*
  198.  * The remaining definitions don't need to be hand-edited in most cases.
  199.  * You may need to change these if you have a machine with unusual data
  200.  * types; for example, "char" not 8 bits, "short" not 16 bits,
  201.  * or "long" not 32 bits.  We don't care whether "int" is 16 or 32 bits,
  202.  * but it had better be at least 16.
  203.  */
  204.  
  205. /* First define the representation of a single pixel element value. */
  206.  
  207. #ifdef EIGHT_BIT_SAMPLES
  208. /* JSAMPLE should be the smallest type that will hold the values 0..255.
  209.  * You can use a signed char by having GETJSAMPLE mask it with 0xFF.
  210.  * If you have only signed chars, and you are more worried about speed than
  211.  * memory usage, it might be a win to make JSAMPLE be short.
  212.  */
  213.  
  214. #ifdef HAVE_UNSIGNED_CHAR
  215.  
  216. typedef unsigned char JSAMPLE;
  217. #define GETJSAMPLE(value)  (value)
  218.  
  219. #else /* not HAVE_UNSIGNED_CHAR */
  220. #ifdef CHAR_IS_UNSIGNED
  221.  
  222. typedef char JSAMPLE;
  223. #define GETJSAMPLE(value)  (value)
  224.  
  225. #else /* not CHAR_IS_UNSIGNED */
  226.  
  227. typedef char JSAMPLE;
  228. #define GETJSAMPLE(value)  ((value) & 0xFF)
  229.  
  230. #endif /* CHAR_IS_UNSIGNED */
  231. #endif /* HAVE_UNSIGNED_CHAR */
  232.  
  233. #define MAXJSAMPLE    255
  234. #define CENTERJSAMPLE    128
  235.  
  236. #endif /* EIGHT_BIT_SAMPLES */
  237.  
  238.  
  239. #ifdef TWELVE_BIT_SAMPLES
  240. /* JSAMPLE should be the smallest type that will hold the values 0..4095. */
  241. /* On nearly all machines "short" will do nicely. */
  242.  
  243. typedef short JSAMPLE;
  244. #define GETJSAMPLE(value)  (value)
  245.  
  246. #define MAXJSAMPLE    4095
  247. #define CENTERJSAMPLE    2048
  248.  
  249. #endif /* TWELVE_BIT_SAMPLES */
  250.  
  251.  
  252. #ifdef SIXTEEN_BIT_SAMPLES
  253. /* JSAMPLE should be the smallest type that will hold the values 0..65535. */
  254.  
  255. #ifdef HAVE_UNSIGNED_SHORT
  256.  
  257. typedef unsigned short JSAMPLE;
  258. #define GETJSAMPLE(value)  (value)
  259.  
  260. #else /* not HAVE_UNSIGNED_SHORT */
  261.  
  262. /* If int is 32 bits this'll be horrendously inefficient storage-wise.
  263.  * But since we don't actually support 16-bit samples (ie lossless coding) yet,
  264.  * I'm not going to worry about making a smarter definition ...
  265.  */
  266. typedef unsigned int JSAMPLE;
  267. #define GETJSAMPLE(value)  (value)
  268.  
  269. #endif /* HAVE_UNSIGNED_SHORT */
  270.  
  271. #define MAXJSAMPLE    65535
  272. #define CENTERJSAMPLE    32768
  273.  
  274. #endif /* SIXTEEN_BIT_SAMPLES */
  275.  
  276.  
  277. /* Here we define the representation of a DCT frequency coefficient.
  278.  * This should be a signed 16-bit value; "short" is usually right.
  279.  * It's important that this be exactly 16 bits, no more and no less;
  280.  * more will cost you a BIG hit of memory, less will give wrong answers.
  281.  */
  282.  
  283. typedef short JCOEF;
  284.  
  285.  
  286. /* The remaining typedefs are used for various table entries and so forth.
  287.  * They must be at least as wide as specified; but making them too big
  288.  * won't cost a huge amount of memory, so we don't provide special
  289.  * extraction code like we did for JSAMPLE.  (In other words, these
  290.  * typedefs live at a different point on the speed/space tradeoff curve.)
  291.  */
  292.  
  293. /* UINT8 must hold at least the values 0..255. */
  294.  
  295. #ifdef HAVE_UNSIGNED_CHAR
  296. typedef unsigned char UINT8;
  297. #else /* not HAVE_UNSIGNED_CHAR */
  298. #ifdef CHAR_IS_UNSIGNED
  299. typedef char UINT8;
  300. #else /* not CHAR_IS_UNSIGNED */
  301. typedef short UINT8;
  302. #endif /* CHAR_IS_UNSIGNED */
  303. #endif /* HAVE_UNSIGNED_CHAR */
  304.  
  305. /* UINT16 must hold at least the values 0..65535. */
  306.  
  307. #ifdef HAVE_UNSIGNED_SHORT
  308. typedef unsigned short UINT16;
  309. #else /* not HAVE_UNSIGNED_SHORT */
  310. typedef unsigned int UINT16;
  311. #endif /* HAVE_UNSIGNED_SHORT */
  312.  
  313. /* INT16 must hold at least the values -32768..32767. */
  314.  
  315. typedef short INT16;
  316.  
  317. /* INT32 must hold signed 32-bit values; if your machine happens */
  318. /* to have 64-bit longs, you might want to change this. */
  319.  
  320. typedef long INT32;
  321.